Add a gtk_scrollable_get_border
authorMatthias Clasen <mclasen@redhat.com>
Wed, 10 Dec 2014 11:45:21 +0000 (06:45 -0500)
committerMatthias Clasen <mclasen@redhat.com>
Wed, 10 Dec 2014 15:01:30 +0000 (10:01 -0500)
Add a vfunc to return a non-scrollable border around scrollables.
This would be nicer as a property, but we can't add properties
to an interface without breaking 3rd party implementations, so
make this an optional vfunc, and handle it not being set.

docs/reference/gtk/gtk3-sections.txt
gtk/gtkscrollable.c
gtk/gtkscrollable.h

index 562249dc563ec9b72b3bb0e63cc295a29ebda11f..fb93d29a267dad8062924f0cd1ce8e38963267db 100644 (file)
@@ -3096,7 +3096,7 @@ gtk_scrollable_get_hscroll_policy
 gtk_scrollable_set_hscroll_policy
 gtk_scrollable_get_vscroll_policy
 gtk_scrollable_set_vscroll_policy
-
+gtk_scrollable_get_border
 
 <SUBSECTION Standard>
 GtkScrollableInterface
index 20028782ae473ae6d4cd47f4e869a9bf84bfeaa8..1ac26b625d604257910fbd9e040cb2ba8351f3a1 100644 (file)
@@ -312,3 +312,31 @@ gtk_scrollable_set_vscroll_policy (GtkScrollable       *scrollable,
 
   g_object_set (scrollable, "vscroll-policy", policy, NULL);
 }
+
+/**
+ * gtk_scrollable_get_border:
+ * @scrollable: a #GtkScrollable
+ * @border: return location for the results
+ *
+ * Returns the size of a non-scrolling border around the
+ * outside of the scrollable. An example for this would
+ * be treeview headers. GTK+ can use this information to
+ * display overlayed graphics, like the overshoot indication,
+ * at the right position.
+ *
+ * Returns: %TRUE if @border has been set
+ *
+ * Since: 3.16
+ */
+gboolean
+gtk_scrollable_get_border (GtkScrollable *scrollable,
+                           GtkBorder     *border)
+{
+  g_return_val_if_fail (GTK_IS_SCROLLABLE (scrollable), FALSE);
+  g_return_val_if_fail (border != NULL, FALSE);
+
+  if (GTK_SCROLLABLE_GET_IFACE (scrollable)->get_border)
+    return GTK_SCROLLABLE_GET_IFACE (scrollable)->get_border (scrollable, border);
+
+  return FALSE;
+}
index 112301f04d7e9324c43617258b4614ee79e35176..a4e0af1f5f8a64bcf01a5df8a048873725795102 100644 (file)
@@ -25,6 +25,7 @@
 #include <gdk/gdk.h>
 #include <gtk/gtkenums.h>
 #include <gtk/gtktypes.h>
+#include <gtk/gtkborder.h>
 
 G_BEGIN_DECLS
 
@@ -39,6 +40,9 @@ typedef struct _GtkScrollableInterface GtkScrollableInterface;
 struct _GtkScrollableInterface
 {
   GTypeInterface base_iface;
+
+  gboolean (* get_border) (GtkScrollable *scrollable,
+                           GtkBorder     *border);
 };
 
 /* Public API */
@@ -65,6 +69,10 @@ GDK_AVAILABLE_IN_ALL
 void                 gtk_scrollable_set_vscroll_policy     (GtkScrollable       *scrollable,
                                                            GtkScrollablePolicy  policy);
 
+GDK_AVAILABLE_IN_3_16
+gboolean             gtk_scrollable_get_border             (GtkScrollable       *scrollable,
+                                                            GtkBorder           *border);
+
 G_END_DECLS
 
 #endif /* __GTK_SCROLLABLE_H__ */